package com.atguigu.gulimall.order;

import org.springframework.amqp.rabbit.annotation.EnableRabbit;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.openfeign.EnableFeignClients;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;


/**
 *使用RabbitMQ
 *  * 1、引入amqp场景;RabbitAutoConfiguration就会自动生效
 *  * 2、给容器中自动配置了
 *  *      RabbitTemplate、AmqpAdmin、CachingConnectionFactory、RabbitMessagingTemplate
 *  * 3、给配置文件中配置spring.rabbitmq信息
 *     4. @EnableRabbit:  开启功能
 *     5. 监听消息，使用@RabbitListener，必须要有@EnableRabbit
 *  *
 *  * Seata控制分布式事务
 *  *  1）、每一个微服务必须创建undo_Log
 *  *  2）、安装事务协调器：seate-server   https://github.com/seata/seata/releases
 *  *  3）、整合
 *  *      1、导入依赖  spring-cloud-starter-alibaba-seata
 *  *      2、解压并启动seata-server：
 *  *          registry.conf:注册中心配置    修改 registry ： nacos
 *  *      3、所有想要用到分布式事务的微服务使用seata DataSourceProxy 代理自己的数据源
 *  *      4、每个微服务，都必须导入   registry.conf   file.conf(默认没有service   需要手动添加)
 *  *          vgroup_mapping.{application.name}-fescar-server-group = "default"
 *  *      5、启动测试分布式事务
 *  *      6、给分布式大事务的入口标注@GlobalTransactional
 *  *      7、每一个远程的小事务用@Trabsactional
 */
@EnableRedisHttpSession     //开启springsession
@EnableRabbit
@EnableFeignClients
@EnableDiscoveryClient
@SpringBootApplication
public class GulimallOrderApplication {

    public static void main(String[] args) {
        SpringApplication.run(GulimallOrderApplication.class, args);
    }

}
